* {
  /* 常规初始化 */
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: "阿里巴巴普惠体";
}
body {
  /* 常规居中显示 */
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;

  min-height: 100vh;
  background-color: #3f3f3f;
}

.box {
  /* flex 让盒子横着排列 */
  display: flex;
  /* 元素之间的距离 */
  gap: 10px;

  /* 3D模式 */
  transform-style: preserve-3d;
  /* 旋转一下，看着立体一点 */
  transform: rotateY(30deg) rotateX(10deg);
}

.box .text {
  /* 单个元素的宽高 */
  width: 100px;
  height: 100px;

  /* 给个定位 */
  position: relative;
  /* 3D模式 */
  transform-style: preserve-3d;
  /* 过度动画时间、动画曲线  */
  transition: 2.5s ease-in-out;
  /* 动画延时，通过 calc 和 --i 计算出每个 text 元素对应的延时时间 */
  transition-delay: calc(0.25s * var(--i));
}
/* 方块左边空的一面 */
.box .text::before {
  content: "";

  width: 100%;
  height: 100%;
  background-color: #373737;

  position: absolute;
  /* 下面的旋转位移都按左边为基础 */
  transform-origin: left;
  /* 调整位置盖住左边面 */
  transform: rotateY(90deg) translateX(-50%);
}
.box .text:first-child:before {
  /* 第一块给个不一样的颜色 */
  background-color: #e95e87;
}
.box:hover .text {
  /* 鼠标放上去旋转一定角度 */
  transform: rotateX(-540deg);
}
.box:hover .text:first-child {
  /* 第一块来个不同方向 */
  transform: rotateX(540deg);
}

.box .text span {
  /* 内部元素居中对齐 */
  display: flex;
  justify-content: center;
  align-items: center;

  width: 100%;
  height: 100%;
  /* 背景渐变颜色 */
  background: linear-gradient(#434343, #535353);
  /* 字体大小、粗细、颜色 */
  font-size: 4em;
  font-weight: 500;
  color: #fff;

  position: absolute;
  /* 3D模式 */
  transform-style: preserve-3d;
  /* 旋转 90deg 的倍数，组成正方体四个面，调整到合适位置 */
  transform: rotateX(calc(90deg * var(--j))) translateZ(50px);
}
.box .text:first-child span {
  /* 第一个颜色不一样 */
  background: linear-gradient(#e97089, #ed82ad);
}
